<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    .outBox{
      height: 200px;
      width: 200px;
      overflow: scroll;
    }
    .innerBox{
      background-color: red;
      height: 600px;
      width: 600px;
    }
  </style>
</head>
<body>
  <div class="outBox" id="box">
    <div class="innerBox">

    </div>
  </div>
</body>
<script>
  // 防抖和节流
  // document.getElementById("box").addEventListener("scroll",debounce(function(){
  //   console.log("我滚了");
  // },300))
  document.getElementById("box").addEventListener("scroll",throttle(function(){
    console.log("我滚了");
  },2000))
  /* 防抖的例子 */
  /* 
  @fn 回调函数
  @timeout执行时间
  */
  function debounce(fn,timeout){
    let timeId=null;
    return function(){
        if(timeId){
          clearTimeout(timeId);
          timeId=null;
        }
        timeId=setTimeout(fn,timeout);//第一次执行
    }
  }
  /* 节流-在时间频繁发生的情况下有规律性的出发*/
  function throttle(fn,timeout){
    let valid = true;
    return function(){
      if(valid){
        valid=false;
        setTimeout(function(){
          fn.call(this)
          valid=true;
        },timeout)
      }
    }
  }
</script>
</html>